package de.mnit.basis.daten.struktur.ordnen.algo;

import de.mnit.basis.daten.struktur.ordnen.S_Sortierbar;

/**
 * @author Michael Nitsche
 */
public class Gnomesort extends A_SortierAlgo {

	protected void sortieren2(S_Sortierbar<?> tab, int... nach) {
	    int oben = 1, laenge=tab.gLaenge();
	    while(oben < laenge)
	        if(this.schwerer(tab,oben,oben+1,nach)) {
	        	tab.vertauschen(oben,oben+1);
	        	if(oben>1)
	        		oben--;
	        }
	        else
	        	oben++;
	}

}
